import requests
import json
import sys
import time

# Disable warnings for SSL Certificate (avoid in production if possible)
requests.packages.urllib3.disable_warnings()

# BMC Configuration
bmc_ip = 

# Redfish Base URLs (without 'redfish/v1')
redfish_base_url = f"https://{bmc_ip}"
session_service_url = f"{redfish_base_url}/redfish/v1/SessionService/Sessions"
systems_url = f"{redfish_base_url}/redfish/v1/Systems"

# Function to handle Redfish requests with retries
def redfish_get(url, headers, max_retries=3, retry_delay=2):
    for attempt in range(max_retries):
        try:
            print(f"Fetching data from: {url}")  # Debugging print
            response = requests.get(url, headers=headers, verify=False)
            response.raise_for_status()  # Raise an exception for HTTP errors
            print(f"Response status code: {response.status_code}")  # Debugging print
            return response.json()
        except requests.exceptions.RequestException as e:
            if attempt < max_retries - 1:  # Retry if not the last attempt
                print(f"Error fetching {url}: {e}. Retrying in {retry_delay} seconds...")
                time.sleep(retry_delay)
            else:
                print(f"Failed to fetch data from: {url}")  # Debugging print
                raise  # Raise the exception if all retries fail

# Create Redfish Session and get X-Auth-Token
session_payload = {"UserName": bmc_user, "Password": bmc_pass}
try:
    print("Creating Redfish session...")  # Debugging print
    response = requests.post(session_service_url, json=session_payload, verify=False)
    response.raise_for_status()
    auth_token = response.headers.get("X-Auth-Token")
    session_location = response.headers.get("Location")
    print(f"Session created. Auth Token: {auth_token}, Session Location: {session_location}")  # Debugging print
except requests.exceptions.RequestException as e:
    print(f"Failed to create Redfish session: {e}")
    sys.exit(1)

auth_headers = {"X-Auth-Token": auth_token}

# Get System Information
try:
    print(f"Fetching systems data from: {systems_url}")  # Debugging print
    systems_data = redfish_get(systems_url, auth_headers)
    print(f"Systems data: {json.dumps(systems_data, indent=4)}")  # Debugging print
except requests.exceptions.RequestException as e:
    print(f"Failed to get system information: {e}")
    sys.exit(1)

# Find the relevant system (assuming the first one for now)
system_url = systems_data["Members"][0]["@odata.id"]
print(f"System URL: {system_url}")  # Debugging print

# Get Storage Information for the system
try:
    storage_url = f"{redfish_base_url}{system_url}/Storage"
    print(f"Fetching storage data from: {storage_url}")  # Debugging print
    storage_data = redfish_get(storage_url, auth_headers)
    print(f"Storage data: {json.dumps(storage_data, indent=4)}")  # Debugging print
except requests.exceptions.RequestException as e:
    print(f"Failed to get storage information: {e}")
    sys.exit(1)

# Check if StorageControllers key exists
if "StorageControllers" not in storage_data:
    print("No StorageControllers found in storage data.")  # Debugging print
    sys.exit(1)

# Iterate through Storage Controllers and count RAID controllers
print("Storage Data:", json.dumps(storage_data, indent=4))

raid_count = 0
for storage_controller in storage_data["StorageControllers"]:
    controller_path = storage_controller["@odata.id"]
    full_controller_url = f"{redfish_base_url}{controller_path}"
    print(f"Fetching controller data from: {full_controller_url}")  # Debugging print
    
    try:
        controller_data = redfish_get(full_controller_url, auth_headers)
        controller_name = controller_data.get("Name", "")
        print(f"Controller Name: {controller_name}")  # Debugging print
        if "RAID" in controller_name.upper():  # Case-insensitive RAID detection
            raid_count += 1
    except requests.exceptions.RequestException as e:
        print(f"Failed to get details for {full_controller_url}: {e}")

# Evaluate RAID configuration
print(f"RAID Count: {raid_count}")  # Debugging print
if raid_count == 1:
    print("Exactly one RAID disk found. Proceeding with the installation.")
elif raid_count == 0:
    print("No RAID disk found. Failing the task.")
    sys.exit(1)
else:
    print(f"Multiple RAID disks found: {raid_count}. Failing the task.")
    sys.exit(1)

# Delete the Redfish Session
try:
    delete_response = requests.delete(session_location, headers=auth_headers, verify=False)
    delete_response.raise_for_status()
    print("Session deleted successfully.")
except requests.exceptions.RequestException as e:
    print(f"Failed to delete session: {e}")
